草庐IT

sql - 在go中参数化sql查询

全部标签

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

ruby-on-rails - 为 Rails 3.1.1 关闭详细的 sql/ActiveRecord

尽管SQL/ActiveRecord调用的冗长功能在大多数情况下都很有用,但在我有一些循环正在进行的情况下,我想将其关闭。有没有办法关闭它?irb(main):055:0>City.first←[1m←[35mCityLoad(1.0ms)←[0mSELECT`cities`.*FROM`cities`LIMIT1=># 最佳答案 在控制台中:禁用:old_logger=ActiveRecord::Base.loggerActiveRecord::Base.logger=nil启用:ActiveRecord::Base.logger

ruby - 将参数传递给新的 sinatra 应用程序

简单的问题:我希望能够在config.ru中将选项传递到我的sinatra应用程序中。这怎么可能?我的config.ru看起来像这样:runMyApp但我想在我的MyApp类中使用它来接受参数:classMyApp但是我想不出一个办法来做到这一点。想法? 最佳答案 使用set/settingsrequire'sinatra/base'classMyApp使用配置文件。参见Sinatra::ConfigFile在contrib中(它也使用set和settings,但从YAML文件加载参数)

ruby - 是否可以在 Ruby 中定义带有默认参数的 block ?

Thisquestion处理传递给Rubyblock的可选参数。我想知道是否也可以用默认值定义参数,以及它的语法是什么。乍一看,答案似乎是“否”:defcall_it&blockblock.callendcall_itdo|x="foo"|p"Calledtheblockwithvalue#{x}"end...结果:my_test.rb:5:syntaxerror,unexpected'=',expecting'|'call_itdo|x="foo"|^my_test.rb:6:syntaxerror,unexpectedtSTRING_BEG,expectingkDOor'{'or'

ruby - 在 Ubuntu 上安装 ruby​​-odbc gem 时出现 "ERROR: sql.h not found"

尝试在Debian/Ubuntu上安装ruby​​-odbcgem会导致以下错误;“错误:找不到sql.h” 最佳答案 这也发生在OSX上,所以brew来拯救:brewinstallunixodbc 关于ruby-在Ubuntu上安装ruby​​-odbcgem时出现"ERROR:sql.hnotfound",我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/17068590/

ruby - 如何制作可选的强参数键但过滤嵌套参数?

我的Controller里有这个:params.require(:item).permit!让我们假设这个rspec规范,它按预期工作:put:update,id:@item.id,item:{name:"newname"}但是,以下原因会导致ActionController::ParameterMissing:put:update,id:@item.id,item:nil它与我用于其他操作的Controller宏有关,我无法通过它控制发送的参数(宏检查用户凭据,所以我真的不关心实际测试#update操作,而我只是为它测试before_filters)。所以我的问题是:如何使param

ruby-on-rails - Rails 3 - 在更新之前使用参数检查对象是否有效

我有一个新手问题。我如何在更新模型对象之前使用新参数检查模型对象是否有效?我想改变它:defupdate@obj=SomeModel.find(params[:id])if@obj.update_attributes(params[:obj])#Thathavebeenupdatedelse#Ups,errors!endend类似的东西:defupdate@obj=SomeModel.find(params[:id])if@obj.valid_with_new_params(params[:obj])@obj.update_attributes(params[:obj])else#Up

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby - 如何获取 Sinatra 应用程序中的所有 URL 参数

使用以下Sinatra应用get'/app'docontent_type:json{"params"=>params}.to_jsonend调用:/app?param1=one¶m2=two¶m2=alt给出以下结果:{"params":{"param1":"one","param2":"alt"}}Params只有两个键,param1和param2。我知道Sinatra将参数设置为散列,但它并不代表所有的URL请求。在Sinatra中有没有办法获取请求中发送的所有URL参数的列表? 最佳答案 机架中的任何请求get

Ruby lambda 参数

此代码按预期工作(什么都不做,甚至不产生警告/错误):l=lambda{|i|}l.call(1)此代码产生警告(警告:block参数的多个值(0表示1)):l=lambda{|i|}l.call此代码因错误而失败(ArgumentError:参数数量错误(0代表2)):l=lambda{|i,y|}l.call我认为lambda需要传递所有参数。从第二个例子中我发现它不是。为什么仅给出一个参数时它可以工作,而使用多个参数时却按预期工作(失败并出现错误)?PS:ruby​​1.8.6(2008-08-11patchlevel287)[universal-darwin9.0]更新:我已经